

## UNIVERSITY OF CAPE TOWN

## DEPARTMENT OF ELECTRICAL ENGINEERING

## EEE226S/EEE233S/EEE234S/EEE370S

Module D: Measurement and Microprocessors

\_\_\_\_\_\_

## FINAL EXAMINATION NOVEMBER 2006

TIME: 2 hours

TOTAL MARKS: 100 (See Note 3 below)

#### **INSTRUCTIONS**

- 1. This is a Closed Book Examination. Candidates will be supplied with the Instruction Set for the 68HCS908GT16 and an ASCII table (attached).
- 2. All numerical answers must be given to the appropriate number of significant figures, and the base of the number system must be indicated if it is not base 10.
- 3. Answer all questions. There are 100 marks available. There is no sub-minimum in this course.

INTERNAL EXAMINER: PROF. J. TAPSON EXTERNAL EXAMINER: DR. D. HOCH

#### Question 1:

A Freescale 68HCS908GT16 microprocessor is to be used to control the heating in a room. It will have a display that shows the desired temperature, and the actual temperature. To raise the desired temperature, one button is pushed. To lower the desired temperature, the other button is pushed.

The circuit is shown below. The processors is connected to push buttons on pins B0 and B1, and to an LCD display on pins D7, D6, D5, and D4, as shown below (all other connections such as power, ground, the oscillator and so on can be assumed to be standard). All resistors are  $1k\Omega$ .



The processor is connected to an LM35 analog temperature sensor via pin B2. The LM35 gives a voltage of 0.01V/°C at its output. Pin B3 is connected to a heater, where logic "0" turns the heater off, and logic "1" turns it on.

Write a program that works as follows:

- The temperature is displayed on the LCD display.
- A desired (setpoint) temperature is also displayed.
- Pushing button PBO lowers the setpoint temperature by 1°C.
- Pushing button PB1 raises the setpoint temperature by 1°C.
- The processor turns the heater on and off depending on the measured and setpoint temperatures.

You may assume that you already have the following subroutines. You do not have to write them:

Delay\_1sec: this subroutine gives a one second delay.

Init\_LCD: Initialises the LCD. Clear\_LCD: Clears the LCD.

Write\_LCD1: Writes the character in the accumulator to line 1 of

the LCD.

Write\_LCD2: Writes the character in the accumulator to line 2 of

the LCD.

GetADC\_B2: this subroutine gets an 8-bit ADC conversion from pin

B2 and returns it in the accumulator.

a) Complete the following program to carry out the actions listed above. You may use all the defined variables and can define extra ones if you wish. You do not need to reproduce all the lines below in you answer book – just write down the missing code.

You do not need to define any of the variables used in the subroutines listed above.

You must provide switch debouncing in your program.

| RomStart                      | EQU     | \$C000          | ;    | Start of program memory   |
|-------------------------------|---------|-----------------|------|---------------------------|
| RamStart                      | EQU     | \$0080          | ;    | Start of data memory      |
| PTB                           | EQU     | \$0004          | ;    | Port B                    |
| PTBPE                         | EQU     | \$0006          | ;    | Port B pullup enable      |
| DDRB                          | EQU     | \$0007          | ;    | Port B direction register |
| PTD                           | EQU     | \$000C          | ;    | Port D                    |
| PTDPE                         | EQU     | \$000B          | ;    | Port D pullup enable      |
| DDRD                          | EQU     | \$000F          | ;    | Port D direction register |
|                               |         |                 |      |                           |
|                               | org     | RamStart        | ;    | Start variables here      |
| _1                            | _       | _               |      |                           |
| Timeout1                      | ds      | 1               |      | Define a byte variable    |
| Count                         | ds      | 1               | ;    | Define a byte variable    |
|                               |         | D 01 1          | _    |                           |
|                               | org     | RomStart        | ,    | Start program here        |
| main_init:                    |         |                 |      |                           |
| ;*****                        | **** V( | OUR CODE STARTS | חבטב | ******                    |
| ,                             | 10      | JOR CODE STARTS | HERE |                           |
|                               |         |                 |      |                           |
|                               |         |                 |      |                           |
| ; * * * * * * * * * * * * * * | **** EN | ID OF YOUR CODE | ***  | ******                    |

total: (30)

#### Question 2:

A 68HCS908GT16 microprocessor is connected to a set of comparators and LEDs as shown in the diagram below. The comparators and resistors are set up to implement a flash ADC. All resistors are  $1k\Omega$ .



a) How many bits of resolution does the ADC have?

(2)

b) What is the size of the least bit as a voltage?

(3)

c) Why is there no EOC or clock line for this converter?

(2)

d) Draw a truth table for the inputs B0-B7 and the ADC output.

(6)

e) What is the output if Vin = 6.3 V?

(2)

f) If the ADC output is to be displayed on the LEDs connected to Port A, as shown in the diagram, complete the following program:

| RomStart | EQU | \$C000 | ; Start of program memory |
|----------|-----|--------|---------------------------|
| RamStart | EQU | \$0080 | ; Start of data memory    |
| PTA      | EQU | \$0000 | ; Port A                  |
| PTAPE    | EQU | \$0002 | ; Port A pullup enable    |

```
$0003
$0004
DDRA
            EQU
                             ; Port A direction register
PTB
            EQU
                              ; Port B
PTBPE
            EQU
                  $0006
                              ; Port B pullup enable
DDRB
            EQU
                  $0007
                              ; Port B direction register
                  $000C
PTD
           EQU
                              ; Port D
PTDPE
            EQU
                  $000B
                              ; Port D pullup enable
                  $000F
DDRD
            EQU
                              ; Port D direction register
            org
                  RamStart
                              ; Start variables here
Timeout1
           ds
                              ; Define a byte variable
Count
           ds
                1
                              ; Define a byte variable
Loop
            ds
                1
                              ; Define a byte variable
                     RomStart
                                ; Start program here
               org
main init:
```

(15)

g) Assuming the comparators are infinitely fast and take no time at all to do a comparison, what is the sampling speed of your converter, in instruction cycles?

(10)

total: (40)

#### Question 3:

The following code shows a subroutine designed to give varying delays.

```
org $0080; start of RAM
dell ds
           1
del2 ds
           1
           $c000 ; Start of program memoroy
;* some program here - ignore
; A set of delay routines of various lengths.
; call delay4 for a short delay, delay1 for an intermediate delay
; and delay5 for a long delay.
delay4:
      mov #$03,del1
      bra delay2
      mov #$FF,del1
      bra delay2 ◀
delay1:
       mov #$A0,del1
```

a) If the instructions take the following number of clock cycles:

| Instruction | Cycles |
|-------------|--------|
| rol         | 3      |
| dbnz        | 5      |
| mov         | 4      |
| nop         | 1      |
| jsr         | 6      |
| bra         | 4      |
| rts         | 4      |

how many cycles would it take from a program call jsr delay4 to the end of the subroutine (rts), inclusive of the jsr and rts instructions? (10)

- b) Write a subroutine which would give a delay of exactly four hundred cycles from jsr to rts. Show mathematically how your subroutine gives this length of delay. (12)
- c) What would you expect the hexadecimal opcode and operands for the instruction mov #\$AO,del1 to be? (3)
- d) What would you expect the hexadecimal opcode and operands for the line **bra delay2** (marked with an arrow in the program above) to be?

(5)

total: (30)

# **ASCII Table**

| Char  | Dec | Hex  | Char  | Dec | Hex  | Char | Dec | Hex  | Char  | Dec | Hex  |
|-------|-----|------|-------|-----|------|------|-----|------|-------|-----|------|
| (nul) | 0   | 0x00 | space | 32  | 0x20 | @    | 64  | 0x40 | `     | 96  | 0x60 |
| (soh) | 1   | 0x01 | !     | 33  | 0x21 | Α    | 65  | 0x41 | а     | 97  | 0x61 |
| (stx) | 2   | 0x02 | "     | 34  | 0x22 | В    | 66  | 0x42 |       | 98  | 0x62 |
| (etx) | 3   | 0x03 | #     | 35  | 0x23 | С    | 67  | 0x43 | С     | 99  | 0x63 |
| (eot) | 4   | 0x04 | \$    | 36  | 0x24 | D    | 68  | 0x44 | d     | 100 | 0x64 |
| (enq) | 5   | 0x05 | %     | 37  | 0x25 | E    | 69  | 0x45 | е     | 101 | 0x65 |
| (ack) | 6   | 0x06 | &     | 38  | 0x26 | F    | 70  | 0x46 | f     | 102 | 0x66 |
| (bel) | 7   | 0x07 | (     | 39  | 0x27 | G    | 71  | 0x47 | g     | 103 | 0x67 |
| (bs)  | 8   | 0x08 | (     | 40  | 0x28 | Н    | 72  | 0x48 | h     | 104 | 0x68 |
| (ht)  | 9   | 0x09 | )     | 41  | 0x29 | I    | 73  | 0x49 | i     | 105 | 0x69 |
| (nl)  | 10  | 0x0a | *     | 42  | 0x2a | J    | 74  | 0x4a | j     | 106 | 0x6a |
| (vt)  | 11  | 0x0b | +     | 43  | 0x2b | K    | 75  | 0x4b | k     | 107 | 0x6b |
| (np)  | 12  | 0x0c | ,     | 44  | 0x2c | L    | 76  | 0x4c | I     | 108 | 0x6c |
| (cr)  | 13  | 0x0d | -     | 45  | 0x2d | M    | 77  | 0x4d | m     | 109 | 0x6d |
| (so)  | 14  | 0x0e |       | 46  | 0x2e | N    | 78  | 0x4e | n     | 110 | 0x6e |
| (si)  | 15  | 0x0f | /     | 47  | 0x2f | 0    | 79  | 0x4f | 0     | 111 | 0x6f |
| (dle) | 16  | 0x10 | 0     | 48  | 0x30 | Р    | 80  | 0x50 | р     | 112 | 0x70 |
| (dc1) | 17  | 0x11 | 1     | 49  | 0x31 | Q    | 81  | 0x51 | q     | 113 | 0x71 |
| (dc2) | 18  | 0x12 | 2     | 50  | 0x32 | R    | 82  | 0x52 | r     | 114 | 0x72 |
| (dc3) | 19  | 0x13 | 3     | 51  | 0x33 | S    | 83  | 0x53 | S     | 115 | 0x73 |
| (dc4) | 20  | 0x14 | 4     | 52  | 0x34 | Т    | 84  | 0x54 | t     | 116 | 0x74 |
| (nak) | 21  | 0x15 | 5     | 53  | 0x35 | U    | 85  | 0x55 | u     | 117 | 0x75 |
| (syn) | 22  | 0x16 | 6     | 54  | 0x36 | V    | 86  | 0x56 | ٧     | 118 | 0x76 |
| (etb) | 23  | 0x17 | 7     | 55  | 0x37 | W    | 87  | 0x57 | W     | 119 | 0x77 |
| (can) | 24  | 0x18 | 8     | 56  | 0x38 | Χ    | 88  | 0x58 | Х     | 120 | 0x78 |
| (em)  | 25  | 0x19 | 9     | 57  | 0x39 | Υ    | 89  | 0x59 | у     | 121 | 0x79 |
| (sub) | 26  | 0x1a | :     | 58  | 0x3a | Z    | 90  | 0x5a | Z     | 122 | 0x7a |
| (esc) | 27  | 0x1b | ,     | 59  | 0x3b | [    | 91  | 0x5b | {     | 123 | 0x7b |
| (fs)  | 28  | 0x1c | <     | 60  | 0x3c | \    | 92  | 0x5c |       | 124 | 0x7c |
| (gs)  | 29  | 0x1d | =     | 61  | 0x3d | ]    | 93  | 0x5d | }     | 125 | 0x7d |
| (rs)  | 30  | 0x1e | >     | 62  | 0x3e | ٨    | 94  | 0x5e | ~     | 126 | 0x7e |
| (us)  | 31  | 0x1f | ?     | 63  | 0x3f | _    | 95  | 0x5f | (del) | 127 | 0x7f |

Table 7-1 HCS08 Instruction Set Summary (Sheet 1 of 6)

|                                                                                                                 |                                                            |                                                                       |   |   |   | ect |   |   | Ñ                                                                       | Ð                                                | Ð                                | (1)<br>Se                            |
|-----------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------------------------------------------------------------|---|---|---|-----|---|---|-------------------------------------------------------------------------|--------------------------------------------------|----------------------------------|--------------------------------------|
| Source<br>Form                                                                                                  | Operation                                                  | Description                                                           | v |   | ı |     |   | С | Address<br>Mode                                                         | Opcode                                           | Operand                          | Bus Cycles <sup>(1)</sup>            |
| ADC #opr8i<br>ADC opr8a<br>ADC opr16a<br>ADC oprx16,X<br>ADC oprx8,X<br>ADC ,X<br>ADC oprx16,SP<br>ADC oprx8,SP | Add with Carry                                             | $A \leftarrow (A) + (M) + (C)$                                        |   |   | _ |     |   |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1                     | A9<br>B9<br>C9<br>D9<br>E9<br>F9<br>9ED9<br>9EE9 | dd<br>hh II<br>ee ff<br>ff       | 2<br>3<br>4<br>4<br>3<br>3<br>5<br>4 |
| ADD #opr8i<br>ADD opr8a<br>ADD opr16a<br>ADD oprx16,X<br>ADD oprx8,X<br>ADD ,X<br>ADD oprx16,SP<br>ADD oprx8,SP | Add without Carry                                          | $A \leftarrow (A) + (M)$                                              |   |   | _ |     |   |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1                     | AB<br>BB<br>CB<br>DB<br>EB<br>FB<br>9EDB<br>9EEB | dd<br>hh II<br>ee ff<br>ff       | 2 3 4 4 3 3 5 4                      |
| AIS #opr8i                                                                                                      | Add Immediate Value (Signed) to Stack Pointer              | $SP \leftarrow (SP) + (M)$<br>M is sign extended to a 16-bit value    | - | _ | _ | -   | _ | _ | IMM                                                                     | A7                                               | ii                               | 2                                    |
| AIX #opr8i                                                                                                      | Add Immediate Value<br>(Signed) to Index<br>Register (H:X) | H:X ← (H:X) + (M) M is sign extended to a 16-bit value                | - | _ | _ | -   | _ | - | IMM                                                                     | AF                                               | ii                               | 2                                    |
| AND #opr8i<br>AND opr8a<br>AND opr16a<br>AND oprx16,X<br>AND oprx8,X<br>AND ,X<br>AND oprx16,SP<br>AND oprx8,SP | Logical AND                                                | A ← (A) & (M)                                                         | 0 | _ | _ |     |   | _ | IMM DIR EXT IX2 IX1 IX SP2 SP1                                          | A4<br>B4<br>C4<br>D4<br>E4<br>F4<br>9ED4<br>9EE4 | dd<br>hh II<br>ee ff<br>ff       | 2 3 4 4 3 3 5 4                      |
| ASL opr8a<br>ASLA<br>ASLX<br>ASL oprx8,X<br>ASL ,X<br>ASL oprx8,SP                                              | Arithmetic Shift Left<br>(Same as LSL)                     | D 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                               |   | _ | _ |     |   |   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1                                   | 38<br>48<br>58<br>68<br>78<br>9E68               |                                  | 5<br>1<br>1<br>5<br>4<br>6           |
| ASR opr8a<br>ASRA<br>ASRX<br>ASR oprx8,X<br>ASR ,X<br>ASR oprx8,SP                                              | Arithmetic Shift Right                                     | b7 b0                                                                 |   | _ | _ |     |   |   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1                                   | 37<br>47<br>57<br>67<br>77<br>9E67               |                                  | 5<br>1<br>1<br>5<br>4<br>6           |
| BCC rel                                                                                                         | Branch if Carry Bit Clear                                  | Branch if (C) = 0                                                     | _ | _ | _ | _   | _ | _ | REL                                                                     | 24                                               |                                  | 3                                    |
| BCLR n,opr8a                                                                                                    | Clear Bit n in Memory                                      | Mn ← 0                                                                | _ | _ | _ | _   | _ | _ | DIR (b0) DIR (b1) DIR (b2) DIR (b3) DIR (b4) DIR (b5) DIR (b6) DIR (b7) | 15<br>17                                         | dd<br>dd<br>dd<br>dd<br>dd<br>dd | 55555555                             |
| BCS rel                                                                                                         | Branch if Carry Bit Set (Same as BLO)                      | Branch if (C) = 1                                                     | _ | - | - | -   | - | - | REL                                                                     | 25                                               | rr                               | 3                                    |
| BEQ rel                                                                                                         | Branch if Equal                                            | Branch if (Z) = 1                                                     | _ | _ | _ | _   | _ | _ | REL                                                                     | 27                                               | rr                               | 3                                    |
| BGE rel                                                                                                         | Branch if Greater Than or<br>Equal To<br>(Signed Operands) | Branch if $(N \oplus V) = 0$                                          | _ | - | _ | -   | - | - | REL                                                                     | 90                                               | rr                               | 3                                    |
| BGND                                                                                                            | Enter Active Background if ENBDM = 1                       | Waits For and Processes BDM<br>Commands Until GO, TRACE1, or<br>TAGGO | - | _ | _ | _   | - | - | INH                                                                     | 82                                               |                                  | 5+                                   |
| BGT rel                                                                                                         | Branch if Greater Than (Signed Operands)                   | Branch if (Z)   (N $\oplus$ V) = 0                                    | - | - | - | -   | - | - | REL                                                                     | 92                                               | rr                               | 3                                    |
| BHCC rel                                                                                                        | Branch if Half Carry Bit<br>Clear                          | Branch if (H) = 0                                                     | - | - | _ | -   | _ | - | REL                                                                     | 28                                               | rr                               | 3                                    |

Table 7-1 HCS08 Instruction Set Summary (Sheet 2 of 6)

|                                                                                                                 |                                                         |                                                                                                                                                       |                |   |   | ect |   |   | SS                                                                      | e<br>e                                       | ρι                                                                   | eS <sup>(1)</sup>                    |
|-----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|---|---|-----|---|---|-------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------|--------------------------------------|
| Source<br>Form                                                                                                  | Operation                                               | Description                                                                                                                                           | v              | Н | ı | N   | z | С | Address<br>Mode                                                         | Opcode                                       | Operand                                                              | Bus Cycles <sup>(1)</sup>            |
| BHCS rel                                                                                                        | Branch if Half Carry Bit<br>Set                         | Branch if (H) = 1                                                                                                                                     | -              | - | - | -   | - | - | REL                                                                     | 29                                           | rr                                                                   | 3                                    |
| BHI rel                                                                                                         | Branch if Higher                                        | Branch if (C) $\mid$ (Z) = 0                                                                                                                          | † <del>-</del> | - | - | -   | - | - | REL                                                                     | 22                                           | rr                                                                   | 3                                    |
| BHS rel                                                                                                         | Branch if Higher or Same (Same as BCC)                  | Branch if (C) = 0                                                                                                                                     | -              | - | - | -   | - | - | REL                                                                     | 24                                           | rr                                                                   | 3                                    |
| BIH rel                                                                                                         | Branch if IRQ Pin High                                  | Branch if IRQ pin = 1                                                                                                                                 | 1-             | - | - | -   | - | - | REL                                                                     | 2F                                           | rr                                                                   | 3                                    |
| BIL rel                                                                                                         | Branch if IRQ Pin Low                                   | Branch if IRQ pin = 0                                                                                                                                 | 1-             | - | - | -   | - | - | REL                                                                     | 2E                                           | rr                                                                   | 3                                    |
| BIT #opr8i<br>BIT opr8a<br>BIT opr16a<br>BIT oprx16,X<br>BIT oprx8,X<br>BIT ,X<br>BIT oprx16,SP<br>BIT oprx8,SP | Bit Test                                                | (A) & (M)<br>(CCR Updated but Operands<br>Not Changed)                                                                                                | 0              | _ | _ |     |   | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1                     |                                              | dd<br>hh II<br>ee ff<br>ff                                           | 2<br>3<br>4<br>4<br>3<br>3<br>5<br>4 |
| BLE rel                                                                                                         | Branch if Less Than<br>or Equal To<br>(Signed Operands) | Branch if (Z)   (N $\oplus$ V) = 1                                                                                                                    | -              | _ | - | -   | - | _ | REL                                                                     | 93                                           | rr                                                                   | 3                                    |
| BLO rel                                                                                                         | Branch if Lower<br>(Same as BCS)                        | Branch if (C) = 1                                                                                                                                     | -              | - | - | -   | - | - | REL                                                                     | 25                                           | rr                                                                   | 3                                    |
| BLS rel                                                                                                         | Branch if Lower or Same                                 | Branch if (C)   (Z) = 1                                                                                                                               | -              | - | - | -   | - | - | REL                                                                     | 23                                           | rr                                                                   | 3                                    |
| BLT rel                                                                                                         | Branch if Less Than (Signed Operands)                   | Branch if (N ⊕ V ) = 1                                                                                                                                | -              | - | - | -   | - | - | REL                                                                     | 91                                           | rr                                                                   | 3                                    |
| BMC rel                                                                                                         | Branch if Interrupt Mask<br>Clear                       | Branch if (I) = 0                                                                                                                                     | -              | - | - | -   | - | - | REL                                                                     | 2C                                           | rr                                                                   | 3                                    |
| BMI rel                                                                                                         | Branch if Minus                                         | Branch if (N) = 1                                                                                                                                     | -              | - | - | -   | - | - | REL                                                                     | 2B                                           | rr                                                                   | 3                                    |
| BMS rel                                                                                                         | Branch if Interrupt Mask<br>Set                         | Branch if (I) = 1                                                                                                                                     | -              | - | - | -   | - | - | REL                                                                     | 2D                                           | rr                                                                   | 3                                    |
| BNE rel                                                                                                         | Branch if Not Equal                                     | Branch if (Z) = 0                                                                                                                                     | -              | - | - | -   | - | - | REL                                                                     | 26                                           | rr                                                                   | 3                                    |
| BPL rel                                                                                                         | Branch if Plus                                          | Branch if $(N) = 0$                                                                                                                                   | _              | - | - | _   | _ | _ | REL                                                                     | 2A                                           |                                                                      | 3                                    |
| BRA rel                                                                                                         | Branch Always                                           | No Test                                                                                                                                               | -              | _ | - | -   | _ | _ | REL                                                                     | 20                                           |                                                                      | 3                                    |
| BRCLR n,opr8a,rel                                                                                               | Branch if Bit <i>n</i> in Memory Clear                  | Branch if (Mn) = 0                                                                                                                                    | _              | _ | _ | _   | _ |   | DIR (b0) DIR (b1) DIR (b2) DIR (b3) DIR (b4) DIR (b5) DIR (b6) DIR (b7) | 03<br>05<br>07<br>09<br>0B<br>0D             | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 55555555                             |
| BRN rel                                                                                                         | Branch Never                                            | Uses 3 Bus Cycles                                                                                                                                     | -              | - | - | -   | - | - | REL                                                                     | 21                                           | rr                                                                   | 3                                    |
| BRSET n,opr8a,rel                                                                                               | Branch if Bit <i>n</i> in Memory<br>Set                 | Branch if (Mn) = 1                                                                                                                                    | _              | _ | _ | _   | _ |   | DIR (b0) DIR (b1) DIR (b2) DIR (b3) DIR (b4) DIR (b5) DIR (b6) DIR (b7) | 02<br>04<br>06<br>08<br>0A<br>0C             | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 55555555                             |
| BSET n,opr8a                                                                                                    | Set Bit <i>n</i> in Memory                              | Mn ← 1                                                                                                                                                | _              | _ | _ | _   | _ | _ | DIR (b0) DIR (b1) DIR (b2) DIR (b3) DIR (b4) DIR (b5) DIR (b6) DIR (b7) | 10<br>12<br>14<br>16<br>18<br>1A<br>1C<br>1E | dd<br>dd<br>dd<br>dd<br>dd<br>dd                                     | 5555555                              |
| BSR rel                                                                                                         | Branch to Subroutine                                    | $PC \leftarrow (PC) + \$0002$<br>push (PCL); $SP \leftarrow (SP) - \$0001$<br>push (PCH); $SP \leftarrow (SP) - \$0001$<br>$PC \leftarrow (PC) + rel$ | _              | _ | _ | _   | _ | _ | REL                                                                     | AD                                           | rr                                                                   | 5                                    |

# Table 7-1 HCS08 Instruction Set Summary (Sheet 3 of 6)

|                                                                                                                  |                                                                 |                                                                                                                                                                                                                                                                                                     |   |   |   | ect |   |   | SS O                                                | e<br>B                                   | pu                         | les <sup>(1)</sup>                   |
|------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|-----|---|---|-----------------------------------------------------|------------------------------------------|----------------------------|--------------------------------------|
| Source<br>Form                                                                                                   | Operation                                                       | Description                                                                                                                                                                                                                                                                                         | V | н | I | N   | z | С | Address<br>Mode                                     | Opcode                                   | Operand                    | Bus Cycles                           |
| CBEQ opr8a,rel<br>CBEQA #opr8i,rel<br>CBEQX #opr8i,rel<br>CBEQ oprx8,X+,rel<br>CBEQ ,X+,rel<br>CBEQ oprx8,SP,rel | Compare and Branch if Equal                                     | Branch if (A) = (M) Branch if (A) = (M) Branch if (X) = (M) Branch if (A) = (M) Branch if (A) = (M) Branch if (A) = (M)                                                                                                                                                                             | _ | - | _ | -   | _ | - | DIR<br>IMM<br>IMM<br>IX1+<br>IX+<br>SP1             | 41<br>51<br>61                           | ff rr<br>rr                | 5<br>4<br>4<br>5<br>5<br>6           |
| CLC                                                                                                              | Clear Carry Bit                                                 | C ← 0                                                                                                                                                                                                                                                                                               | - | - | _ | _   | _ | 0 | INH                                                 | 98                                       |                            | 1                                    |
| CLI                                                                                                              | Clear Interrupt Mask Bit                                        | I ← 0                                                                                                                                                                                                                                                                                               | - | - | 0 | _   | - | - | INH                                                 | 9A                                       |                            | 1                                    |
| CLR opr8a<br>CLRA<br>CLRX<br>CLRH<br>CLR oprx8,X<br>CLR ,X<br>CLR oprx8,SP                                       | Clear                                                           | $\begin{array}{l} M \leftarrow \$00 \\ A \leftarrow \$00 \\ X \leftarrow \$00 \\ X \leftarrow \$00 \\ H \leftarrow \$00 \\ M \leftarrow \$00 \\ M \leftarrow \$00 \\ M \leftarrow \$00 \\ \end{array}$                                                                                              | 0 | _ | _ | 0   | 1 | _ | DIR<br>INH<br>INH<br>INH<br>IX1<br>IX<br>SP1        | 3F<br>4F<br>5F<br>8C<br>6F<br>7F<br>9E6F |                            | 5<br>1<br>1<br>1<br>5<br>4<br>6      |
| CMP #opr8i<br>CMP opr8a<br>CMP opr16a<br>CMP oprx16,X<br>CMP oprx8,X<br>CMP ,X<br>CMP oprx16,SP<br>CMP oprx8,SP  | Compare Accumulator with Memory                                 | (A) – (M)<br>(CCR Updated But Operands Not<br>Changed)                                                                                                                                                                                                                                              |   | _ | _ |     |   |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 |                                          | dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>4<br>3<br>3<br>5<br>4 |
| COM opr8a<br>COMA<br>COMX<br>COM oprx8,X<br>COM ,X<br>COM oprx8,SP                                               | Complement<br>(One's Complement)                                | $\begin{array}{l} M \leftarrow (\overline{M}) = \$FF - (M) \\ A \leftarrow (\overline{A}) = \$FF - (A) \\ X \leftarrow (\overline{X}) = \$FF - (X) \\ M \leftarrow (\overline{M}) = \$FF - (M) \\ M \leftarrow (\overline{M}) = \$FF - (M) \\ M \leftarrow (\overline{M}) = \$FF - (M) \end{array}$ | 0 | _ | _ |     |   | 1 | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 33<br>43<br>53<br>63<br>73<br>9E63       | ff                         | 5<br>1<br>1<br>5<br>4<br>6           |
| CPHX opr16a<br>CPHX #opr16i<br>CPHX opr8a<br>CPHX oprx8,SP                                                       | Compare Index Register (H:X) with Memory                        | (H:X) – (M:M + \$0001)<br>(CCR Updated But Operands Not<br>Changed)                                                                                                                                                                                                                                 |   | _ | _ |     |   |   | EXT<br>IMM<br>DIR<br>SP1                            | 3E<br>65<br>75<br>9EF3                   | dd                         | 6<br>3<br>5<br>6                     |
| CPX #opr8i<br>CPX opr8a<br>CPX opr16a<br>CPX oprx16,X<br>CPX oprx8,X<br>CPX,X<br>CPX oprx16,SP<br>CPX oprx8,SP   | Compare X (Index<br>Register Low) with<br>Memory                | (X) – (M)<br>(CCR Updated But Operands Not<br>Changed)                                                                                                                                                                                                                                              |   | _ | _ |     |   |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 |                                          | dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>4<br>3<br>3<br>5<br>4 |
| DAA                                                                                                              | Decimal Adjust<br>Accumulator After ADD or<br>ADC of BCD Values | (A) <sub>10</sub>                                                                                                                                                                                                                                                                                   | U | - | - |     |   |   | INH                                                 | 72                                       |                            | 1                                    |
| DBNZ opr8a,rel<br>DBNZA rel<br>DBNZX rel<br>DBNZ oprx8,X,rel<br>DBNZ ,X,rel<br>DBNZ oprx8,SP,rel                 | Decrement and Branch if<br>Not Zero                             | Decrement A, X, or M<br>Branch if (result) ≠ 0<br>DBNZX Affects X Not H                                                                                                                                                                                                                             | _ | _ | _ | _   | _ | _ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3B<br>4B<br>5B<br>6B<br>7B<br>9E6B       | rr<br>ff rr<br>rr          | 7<br>4<br>4<br>7<br>6<br>8           |
| DEC opr8a<br>DECA<br>DECX<br>DEC oprx8,X<br>DEC ,X<br>DEC oprx8,SP                                               | Decrement                                                       | $\begin{array}{l} M \leftarrow (M) - \$01 \\ A \leftarrow (A) - \$01 \\ X \leftarrow (X) - \$01 \\ M \leftarrow (M) - \$01 \\ \end{array}$                                                                         |   | _ | _ |     |   | _ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3A<br>4A<br>5A<br>6A<br>7A<br>9E6A       | ff                         | 5<br>1<br>1<br>5<br>4<br>6           |
| DIV                                                                                                              | Divide                                                          | A ← (H:A)÷(X)<br>H ← Remainder                                                                                                                                                                                                                                                                      | - | - | _ | -   |   |   | INH                                                 | 52                                       |                            | 6                                    |

Table 7-1 HCS08 Instruction Set Summary (Sheet 4 of 6)

|                                                                                                                 |                                            |                                                                                                                                                                                                                             |   |   |   | ect |   |   | SS                                                  | a e                                            | ρι                         | es <sup>(1)</sup>                    |
|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|-----|---|---|-----------------------------------------------------|------------------------------------------------|----------------------------|--------------------------------------|
| Source<br>Form                                                                                                  | Operation                                  | Description                                                                                                                                                                                                                 | v | н | I | N   | z | С | Address<br>Mode                                     | Opcode                                         | Operand                    | Bus Cycles <sup>(1)</sup>            |
| EOR #opr8i<br>EOR opr8a<br>EOR opr16a<br>EOR oprx16,X<br>EOR oprx8,X<br>EOR, X<br>EOR oprx16,SP<br>EOR oprx8,SP | Exclusive OR<br>Memory with<br>Accumulator | $A \leftarrow (A \oplus M)$                                                                                                                                                                                                 | 0 | _ | _ |     |   | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 |                                                | dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>4<br>3<br>3<br>5<br>4 |
| INC opr8a<br>INCA<br>INCX<br>INC oprx8,X<br>INC oprx8,X<br>INC oprx8,SP                                         | Increment                                  | $\begin{array}{l} M \leftarrow (M) + \$01 \\ A \leftarrow (A) + \$01 \\ X \leftarrow (X) + \$01 \\ M \leftarrow (M) + \$01 \\ \end{array}$ |   | _ | _ |     |   | _ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3C<br>4C<br>5C<br>6C<br>7C<br>9E6C             |                            | 5<br>1<br>1<br>5<br>4<br>6           |
| JMP opr8a<br>JMP opr16a<br>JMP oprx16,X<br>JMP oprx8,X<br>JMP ,X                                                | Jump                                       | PC ← Jump Address                                                                                                                                                                                                           | _ | _ | _ | _   | _ | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX                      | CC                                             | dd<br>hh II<br>ee ff<br>ff | 3<br>4<br>4<br>3<br>3                |
| JSR opr8a<br>JSR opr16a<br>JSR oprx16,X<br>JSR oprx8,X<br>JSR ,X                                                | Jump to Subroutine                         | $PC \leftarrow (PC) + n \ (n = 1, 2, \text{ or } 3)$<br>$Push \ (PCL); \ SP \leftarrow (SP) - \$0001$<br>$Push \ (PCH); \ SP \leftarrow (SP) - \$0001$<br>$PC \leftarrow Unconditional \ Address$                           | _ | _ | _ | _   | _ | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX                      | CD                                             | dd<br>hh II<br>ee ff<br>ff | 5<br>6<br>6<br>5<br>5                |
| LDA #opr8i<br>LDA opr8a<br>LDA opr16a<br>LDA oprx16,X<br>LDA oprx8,X<br>LDA ,X<br>LDA oprx16,SP<br>LDA oprx8,SP | Load Accumulator from<br>Memory            | $A \leftarrow (M)$                                                                                                                                                                                                          | 0 | _ | _ |     |   | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 |                                                | dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>4<br>3<br>3<br>5<br>4 |
| LDHX #opr16i<br>LDHX opr8a<br>LDHX opr16a<br>LDHX X<br>LDHX oprx16,X<br>LDHX oprx8,X<br>LDHX oprx8,SP           | Load Index Register (H:X) from Memory      | H:X ← (M:M + \$0001)                                                                                                                                                                                                        | 0 | _ | _ |     |   | _ | IMM<br>DIR<br>EXT<br>IX<br>IX2<br>IX1<br>SP1        | 45<br>55<br>32<br>9EAE<br>9EBE<br>9ECE<br>9EFE | hh II<br>ee ff<br>ff       | 3455655                              |
| LDX #opr8i<br>LDX opr8a<br>LDX opr16a<br>LDX oprx16,X<br>LDX oprx8,X<br>LDX ,X<br>LDX oprx16,SP<br>LDX oprx8,SP | Load X (Index Register<br>Low) from Memory | $X \leftarrow (M)$                                                                                                                                                                                                          | 0 | _ |   |     |   | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 | BE<br>CE                                       | hh II<br>ee ff<br>ff       | 23443354                             |
| LSL opr8a<br>LSLA<br>LSLX<br>LSL oprx8,X<br>LSL ,X<br>LSL oprx8,SP                                              | Logical Shift Left<br>(Same as ASL)        | C 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                     |   | _ | _ |     |   |   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 38<br>48<br>58<br>68<br>78<br>9E68             | ff                         | 5<br>1<br>1<br>5<br>4<br>6           |
| LSR opr8a<br>LSRA<br>LSRX<br>LSR oprx8,X<br>LSR ,X<br>LSR oprx8,SP                                              | Logical Shift Right                        | 0 - C b7 b0                                                                                                                                                                                                                 |   | _ | _ | 0   |   |   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 34<br>44<br>54<br>64<br>74<br>9E64             | ff                         | 5<br>1<br>1<br>5<br>4<br>6           |
| MOV opr8a,opr8a<br>MOV opr8a,X+<br>MOV #opr8i,opr8a<br>MOV ,X+,opr8a                                            | Move                                       | $(M)_{destination} \leftarrow (M)_{source}$<br>$H:X \leftarrow (H:X) + \$0001$ in<br>IX+/DIR and $DIR/IX+$ Modes                                                                                                            | 0 | - | _ |     |   | - | DIR/DIR<br>DIR/IX+<br>IMM/DIR<br>IX+/DIR            | 5E<br>6E<br>7E                                 | ii dd                      | 5<br>5<br>4<br>5                     |
| MUL                                                                                                             | Unsigned multiply                          | $X:A \leftarrow (X) \times (A)$                                                                                                                                                                                             | - | 0 | - | -   | - | 0 | INH                                                 | 42                                             |                            | 5                                    |

# Table 7-1 HCS08 Instruction Set Summary (Sheet 5 of 6)

|                                                                                                                 |                                            |                                                                                                                                                                                                                                                                                                       |    | ( | Eff<br>on ( | ec<br>CC     |   |   | s o                                                 | e<br>B                             | pu                         | les <sup>(1)</sup>                   |
|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|-------------|--------------|---|---|-----------------------------------------------------|------------------------------------|----------------------------|--------------------------------------|
| Source<br>Form                                                                                                  | Operation                                  | Description                                                                                                                                                                                                                                                                                           | v  | н | ı           | N            | z | С | Address<br>Mode                                     | Opcode                             | Operand                    | Bus Cycles <sup>(1)</sup>            |
| NEG opr8a<br>NEGA<br>NEGX<br>NEG oprx8,X<br>NEG ,X<br>NEG oprx8,SP                                              | Negate<br>(Two's Complement)               | $\begin{array}{l} M \leftarrow - \; (M) = \$00 - (M) \\ A \leftarrow - \; (A) = \$00 - (A) \\ X \leftarrow - \; (X) = \$00 - (X) \\ M \leftarrow - \; (M) = \$00 - (M) \\ M \leftarrow - \; (M) = \$00 - (M) \\ M \leftarrow - \; (M) = \$00 - (M) \\ M \leftarrow - \; (M) = \$00 - (M) \end{array}$ |    | _ | _           |              |   |   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 30<br>40<br>50<br>60<br>70<br>9E60 | ff                         | 5<br>1<br>1<br>5<br>4<br>6           |
| NOP                                                                                                             | No Operation                               | Uses 1 Bus Cycle                                                                                                                                                                                                                                                                                      | -  | - | -           | -            | - | - | INH                                                 | 9D                                 |                            | 1                                    |
| NSA                                                                                                             | Nibble Swap<br>Accumulator                 | $A \leftarrow (A \text{[3:0]:A[7:4]})$                                                                                                                                                                                                                                                                | -  | - | -           | -            | - | - | INH                                                 | 62                                 |                            | 1                                    |
| ORA #opr8i<br>ORA opr8a<br>ORA opr16a<br>ORA oprx16,X<br>ORA oprx8,X<br>ORA ,X<br>ORA oprx16,SP<br>ORA oprx8,SP | Inclusive OR Accumulator and Memory        | A ← (A)   (M)                                                                                                                                                                                                                                                                                         | 0  | _ | _           |              |   | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 |                                    | dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>4<br>3<br>3<br>5<br>4 |
| PSHA                                                                                                            | Push Accumulator onto Stack                | Push (A); SP ← (SP) – \$0001                                                                                                                                                                                                                                                                          | -  | - | -           | -            | - | _ | INH                                                 | 87                                 |                            | 2                                    |
| PSHH                                                                                                            | Push H (Index Register<br>High) onto Stack | Push (H); SP ← (SP) – \$0001                                                                                                                                                                                                                                                                          | -  | - | -           | -            | - | - | INH                                                 | 8B                                 |                            | 2                                    |
| PSHX                                                                                                            | Push X (Index Register<br>Low) onto Stack  | Push (X); SP ← (SP) – \$0001                                                                                                                                                                                                                                                                          | -  | - | -           | -            | - | - | INH                                                 | 89                                 |                            | 2                                    |
| PULA                                                                                                            | Pull Accumulator from Stack                | SP ← (SP + \$0001); Pull (A)                                                                                                                                                                                                                                                                          | -  | - | -           | -            | - | - | INH                                                 | 86                                 |                            | 3                                    |
| PULH                                                                                                            | Pull H (Index Register<br>High) from Stack | SP ← (SP + \$0001); Pull (H)                                                                                                                                                                                                                                                                          | -  | - | -           | -            | - | - | INH                                                 | 8A                                 |                            | 3                                    |
| PULX                                                                                                            | Pull X (Index Register<br>Low) from Stack  | SP ← (SP + \$0001); Pull (X)                                                                                                                                                                                                                                                                          | -  | - | -           | -            | - | - | INH                                                 | 88                                 |                            | 3                                    |
| ROL opr8a<br>ROLA<br>ROLX<br>ROL oprx8,X<br>ROL ,X<br>ROL oprx8,SP                                              | Rotate Left through Carry                  | b7 b0                                                                                                                                                                                                                                                                                                 |    | _ | _           |              |   |   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 39<br>49<br>59<br>69<br>79<br>9E69 |                            | 5<br>1<br>1<br>5<br>4<br>6           |
| ROR opr8a<br>RORA<br>RORX<br>ROR oprx8,X<br>ROR ,X<br>ROR oprx8,SP                                              | Rotate Right through<br>Carry              | b7 b0                                                                                                                                                                                                                                                                                                 |    | _ | _           |              |   |   | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 36<br>46<br>56<br>66<br>76<br>9E66 |                            | 5<br>1<br>1<br>5<br>4<br>6           |
| RSP                                                                                                             | Reset Stack Pointer                        | $SP \leftarrow \$FF$ (High Byte Not Affected)                                                                                                                                                                                                                                                         | -  | - | -           | -            | - | - | INH                                                 | 9C                                 |                            | 1                                    |
| RTI                                                                                                             | Return from Interrupt                      | $\begin{array}{l} SP \leftarrow (SP) + \$0001; \; Pull \; (CCR) \\ SP \leftarrow (SP) + \$0001; \; Pull \; (A) \\ SP \leftarrow (SP) + \$0001; \; Pull \; (X) \\ SP \leftarrow (SP) + \$0001; \; Pull \; (PCH) \\ SP \leftarrow (SP) + \$0001; \; Pull \; (PCL) \end{array}$                          |    |   |             |              |   |   | INH                                                 | 80                                 |                            | 9                                    |
| RTS                                                                                                             | Return from Subroutine                     | SP ← SP + \$0001; Pull (PCH)<br>SP ← SP + \$0001; Pull (PCL)                                                                                                                                                                                                                                          | -  | - | -           | -            | - | - | INH                                                 | 81                                 |                            | 6                                    |
| SBC #opr8i<br>SBC opr8a<br>SBC opr16a<br>SBC oprx16,X<br>SBC oprx8,X<br>SBC ,X<br>SBC oprx16,SP<br>SBC oprx8,SP | Subtract with Carry                        | $A \leftarrow (A) - (M) - (C)$                                                                                                                                                                                                                                                                        |    | _ | _           |              |   |   | IMM DIR EXT IX2 IX1 IX SP2 SP1                      |                                    | dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>4<br>3<br>3<br>5<br>4 |
| SEC SEC                                                                                                         | Set Carry Bit                              | C ← 1                                                                                                                                                                                                                                                                                                 | +  | - | -           | +            | - | 1 | INH                                                 | 99                                 |                            | 1                                    |
| SEI                                                                                                             | Set Interrupt Mask Bit                     | I ← 1                                                                                                                                                                                                                                                                                                 | 1- | - | 1           | <del> </del> | - | - | INH                                                 | 9B                                 |                            | 1                                    |

Table 7-1 HCS08 Instruction Set Summary (Sheet 6 of 6)

| _                                                                                                                         |                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                |   |   |   | ec<br>CC |   |   | SS                                                  | e e                                | pu                         | es <sup>(1)</sup>                    |
|---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----------|---|---|-----------------------------------------------------|------------------------------------|----------------------------|--------------------------------------|
| Source<br>Form                                                                                                            | Operation                                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                    | v | н | ı | N        | z | С | Address<br>Mode                                     | Opcode                             | Operand                    | Bus Cycles <sup>(1)</sup>            |
| STA opr8a<br>STA opr16a<br>STA oprx16,X<br>STA oprx8,X<br>STA ,X<br>STA oprx16,SP<br>STA oprx8,SP                         | Store Accumulator in<br>Memory                                         | $M \leftarrow (A)$                                                                                                                                                                                                                                                                                                                                                                                                             | 0 | _ | _ |          |   | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1        | D7                                 | hh II<br>ee ff<br>ff       | 3<br>4<br>4<br>3<br>2<br>5<br>4      |
| STHX opr8a<br>STHX opr16a<br>STHX oprx8,SP                                                                                | Store H:X (Index Reg.)                                                 | (M:M + \$0001) ← (H:X)                                                                                                                                                                                                                                                                                                                                                                                                         | 0 | _ | - |          |   | _ | DIR<br>EXT<br>SP1                                   | 35<br>96<br>9EFF                   | hh II                      | 4<br>5<br>5                          |
| STOP                                                                                                                      | Enable Interrupts:<br>Stop Processing<br>Refer to MCU<br>Documentation | I bit $\leftarrow$ 0; Stop Processing                                                                                                                                                                                                                                                                                                                                                                                          | - | _ | 0 | -        | - | _ | INH                                                 | 8E                                 |                            | 2+                                   |
| STX opr8a<br>STX opr16a<br>STX oprx16,X<br>STX oprx8,X<br>STX ,X<br>STX oprx16,SP<br>STX oprx8,SP                         | Store X (Low 8 Bits of<br>Index Register)<br>in Memory                 | $M \leftarrow (X)$                                                                                                                                                                                                                                                                                                                                                                                                             | 0 | _ | _ |          |   | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1        | DF                                 | hh II<br>ee ff<br>ff       | 3<br>4<br>4<br>3<br>2<br>5<br>4      |
| SUB #opr8i<br>SUB opr8a<br>SUB opr16a<br>SUB oprx16,X<br>SUB oprx8,X<br>SUB ,X<br>SUB ,X<br>SUB oprx16,SP<br>SUB oprx8,SP | Subtract                                                               | $A \leftarrow (A) - (M)$                                                                                                                                                                                                                                                                                                                                                                                                       |   | _ | _ |          |   |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 |                                    | dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>4<br>3<br>3<br>5<br>4 |
| SWI                                                                                                                       | Software Interrupt                                                     | $\begin{array}{c} PC \leftarrow (PC) + \$0001 \\ Push \ (PCL); \ SP \leftarrow (SP) - \$0001 \\ Push \ (PCH); \ SP \leftarrow (SP) - \$0001 \\ Push \ (X); \ SP \leftarrow (SP) - \$0001 \\ Push \ (A); \ SP \leftarrow (SP) - \$0001 \\ Push \ (CCR); \ SP \leftarrow (SP) - \$0001 \\ I \leftarrow I; \ PCH \leftarrow Interrupt \ Vector \ High \ Byte \\ PCL \leftarrow Interrupt \ Vector \ Low \ Byte \\ \\ \end{array}$ | _ | _ | 1 | _        | _ | _ | INH                                                 | 83                                 |                            | 11                                   |
| TAP                                                                                                                       | Transfer Accumulator to CCR                                            | CCR ← (A)                                                                                                                                                                                                                                                                                                                                                                                                                      |   |   |   |          |   |   | INH                                                 | 84                                 |                            | 1                                    |
| TAX                                                                                                                       | Transfer Accumulator to X (Index Register Low)                         | X ← (A)                                                                                                                                                                                                                                                                                                                                                                                                                        | - | _ | _ | -        | - | - | INH                                                 | 97                                 |                            | 1                                    |
| TPA                                                                                                                       | Transfer CCR to Accumulator                                            | $A \leftarrow (CCR)$                                                                                                                                                                                                                                                                                                                                                                                                           | - | - | - | -        | - | - | INH                                                 | 85                                 |                            | 1                                    |
| TST opr8a<br>TSTA<br>TSTX<br>TST oprx8,X<br>TST ,X<br>TST oprx8,SP                                                        | Test for Negative or Zero                                              | (M) - \$00<br>(A) - \$00<br>(X) - \$00<br>(M) - \$00<br>(M) - \$00<br>(M) - \$00                                                                                                                                                                                                                                                                                                                                               | 0 | _ | _ |          |   | - | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3D<br>4D<br>5D<br>6D<br>7D<br>9E6D | ff                         | 4<br>1<br>1<br>4<br>3<br>5           |
| TSX                                                                                                                       | Transfer SP to Index Reg.                                              | H:X ← (SP) + \$0001                                                                                                                                                                                                                                                                                                                                                                                                            | _ | _ | _ | _        | _ | - | INH                                                 | 95                                 |                            | 2                                    |
| TXA                                                                                                                       | Transfer X (Index Reg. Low) to Accumulator                             | $A \leftarrow (X)$                                                                                                                                                                                                                                                                                                                                                                                                             | _ | _ | _ | _        | _ | Ŀ | INH                                                 | 9F                                 |                            | 1                                    |
| TXS                                                                                                                       | Transfer Index Reg. to SP                                              | SP ← (H:X) − \$0001                                                                                                                                                                                                                                                                                                                                                                                                            | _ | _ | _ | _        | _ | _ | INH                                                 | 94                                 |                            | 2                                    |
| WAIT                                                                                                                      | Enable Interrupts; Wait for Interrupt                                  | I bit ← 0; Halt CPU                                                                                                                                                                                                                                                                                                                                                                                                            | - | _ | 0 | -        | - | _ | INH                                                 | 8F                                 |                            | 2+                                   |

### NOTES:

1. Bus clock frequency is one-half of the CPU clock frequency.

Table 7-2 Opcode Map (Sheet 1 of 2)

| Bit-Manipulation                     | Branch  |                       | Rea                    | ad-Modify-W            | /rite                  |                       | Cor                    | ntrol                |                      |                      | Register             | /Memory              |                      |                     |
|--------------------------------------|---------|-----------------------|------------------------|------------------------|------------------------|-----------------------|------------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|---------------------|
| 00 5 10<br>BRSET0 BSET<br>3 DIR 2 DI |         | 30 5<br>NEG<br>2 DIR  | 40 1<br>NEGA<br>1 INH  | 50 1<br>NEGX<br>1 INH  | 60 5<br>NEG<br>2 IX1   | 70 4<br>NEG<br>1 IX   | 80 9<br>RTI<br>1 INH   | 90 3<br>BGE<br>2 REL | A0 2<br>SUB<br>2 IMM | B0 3<br>SUB<br>2 DIR | SUB                  | D0 4<br>SUB<br>3 IX2 | E0 3<br>SUB<br>2 IX1 | F0 3<br>SUB<br>1 IX |
| 01 5 11<br>BRCLR0 BCLR<br>3 DIR 2 DI | R 2 REL | 31 5<br>CBEQ<br>3 DIR | 41 4<br>CBEQA<br>3 IMM | 51 4<br>CBEQX<br>3 IMM | 61 5<br>CBEQ<br>3 IX1+ | 71 5<br>CBEQ<br>2 IX+ | 81 6<br>RTS<br>1 INH   | 91 3<br>BLT<br>2 REL | A1 2<br>CMP<br>2 IMM | CMP<br>2 DIR         | CMP<br>3 EXT         | D1 4<br>CMP<br>3 IX2 | E1 3<br>CMP<br>2 IX1 | F1 3<br>CMP<br>1 IX |
| 02 5 12                              | R 2 REL | 32 5                  | 42 5                   | 52 6                   | 62 1                   | 72 1                  | 82 5+                  | 92 3                 | A2 2                 | B2 3                 | C2 4                 | D2 4                 | E2 3                 | F2 3                |
| BRSET1 BSET                          |         | LDHX                  | MUL                    | DIV                    | NSA                    | DAA                   | BGND                   | BGT                  | SBC                  | SBC                  | SBC                  | SBC                  | SBC                  | SBC                 |
| 3 DIR 2 DI                           |         | 3 EXT                 | 1 INH                  | 1 INH                  | 1 INH                  | 1 INH                 | 1 INH                  | 2 REL                | 2 IMM                | 2 DIR                | 3 EXT                | 3 IX2                | 2 IX1                | 1 IX                |
| 03 5 13<br>BRCLR1 BCLR<br>3 DIR 2 DI |         | COM<br>2 DIR          | 43 1<br>COMA<br>1 INH  | 53 1<br>COMX<br>1 INH  | 63 5<br>COM<br>2 IX1   | 73 4<br>COM<br>1 IX   | 83 11<br>SWI<br>1 INH  | 93 3<br>BLE<br>2 REL | A3 2<br>CPX<br>2 IMM | CPX<br>2 DIR         | C3 4<br>CPX<br>3 EXT | D3 4<br>CPX<br>3 IX2 | E3 3<br>CPX<br>2 IX1 | F3 3<br>CPX<br>1 IX |
| 04 5 14                              | R 2 REL | 34 5                  | 44 1                   | 54 1                   | 64 5                   | 74 4                  | 84 1                   | 94 2                 | A4 2                 | B4 3                 | C4 4                 | D4 4                 | E4 3                 | F4 3                |
| BRSET2 BSET                          |         | LSR                   | LSRA                   | LSRX                   | LSR                    | LSR                   | TAP                    | TXS                  | AND                  | AND                  | AND                  | AND                  | AND                  | AND                 |
| 3 DIR 2 DI                           |         | 2 DIR                 | 1 INH                  | 1 INH                  | 2 IX1                  | 1 IX                  | 1 INH                  | 1 INH                | 2 IMM                | 2 DIR                | 3 EXT                | 3 IX2                | 2 IX1                | 1 IX                |
| 05 5 15                              |         | 35 4                  | 45 3                   | 55 4                   | 65 3                   | 75 5                  | 85 1                   | 95 2                 | A5 2                 | B5 3                 | C5 4                 | D5 4                 | E5 3                 | F5 3                |
| BRCLR2 BCLR                          |         | STHX                  | LDHX                   | LDHX                   | CPHX                   | CPHX                  | TPA                    | TSX                  | BIT                  | BIT                  | BIT                  | BIT                  | BIT                  | BIT                 |
| 3 DIR 2 DI                           |         | 2 DIR                 | 3 IMM                  | 2 DIR                  | 3 IMM                  | 2 DIR                 | 1 INH                  | 1 INH                | 2 IMM                | 2 DIR                | 3 EXT                | 3 IX2                | 2 IX1                | 1 IX                |
| 06 5 16                              |         | 36 5                  | 46 1                   | 56 1                   | 66 5                   | 76 4                  | 86 3                   | 96 5                 | A6 2                 | B6 3                 | C6 4                 | D6 4                 | E6 3                 | F6 3                |
| BRSET3 BSET                          |         | ROR                   | RORA                   | RORX                   | ROR                    | ROR                   | PULA                   | STHX                 | LDA                  | LDA                  | LDA                  | LDA                  | LDA                  | LDA                 |
| 3 DIR 2 DI                           |         | 2 DIR                 | 1 INH                  | 1 INH                  | 2 IX1                  | 1 IX                  | 1 INH                  | 3 EXT                | 2 IMM                | 2 DIR                | 3 EXT                | 3 IX2                | 2 IX1                | 1 IX                |
| 07 5 17                              |         | 37 5                  | 47 1                   | 57 1                   | 67 5                   | 77 4                  | 87 2                   | 97 1                 | A7 2                 | B7 3                 | C7 4                 | D7 4                 | E7 3                 | F7 2                |
| BRCLR3 BCLR                          |         | ASR                   | ASRA                   | ASRX                   | ASR                    | ASR                   | PSHA                   | TAX                  | AIS                  | STA                  | STA                  | STA                  | STA                  | STA                 |
| 3 DIR 2 DI                           |         | 2 DIR                 | 1 INH                  | 1 INH                  | 2 IX1                  | 1 IX                  | 1 INH                  | 1 INH                | 2 IMM                | 2 DIR                | 3 EXT                | 3 IX2                | 2 IX1                | 1 IX                |
| 08 5 18                              |         | 38 5                  | 48 1                   | 58 1                   | 68 5                   | 78 4                  | 88 3                   | 98 1                 | A8 2                 | B8 3                 | C8 4                 | D8 4                 | E8 3                 | F8 3                |
| BRSET4 BSET                          |         | LSL                   | LSLA                   | LSLX                   | LSL                    | LSL                   | PULX                   | CLC                  | EOR                  | EOR                  | EOR                  | EOR                  | EOR                  | EOR                 |
| 3 DIR 2 DI                           |         | 2 DIR                 | 1 INH                  | 1 INH                  | 2 IX1                  | 1 IX                  | 1 INH                  | 1 INH                | 2 IMM                | 2 DIR                | 3 EXT                | 3 IX2                | 2 IX1                | 1 IX                |
| 09 5 19                              |         | 39 5                  | 49 1                   | 59 1                   | 69 5                   | 79 4                  | 89 2                   | 99 1                 | A9 2                 | B9 3                 | C9 4                 | D9 4                 | E9 3                 | F9 3                |
| BRCLR4 BCLR                          |         | ROL                   | ROLA                   | ROLX                   | ROL                    | ROL                   | PSHX                   | SEC                  | ADC                  | ADC                  | ADC                  | ADC                  | ADC                  | ADC                 |
| 3 DIR 2 DI                           |         | 2 DIR                 | 1 INH                  | 1 INH                  | 2 IX1                  | 1 IX                  | 1 INH                  | 1 INH                | 2 IMM                | 2 DIR                | 3 EXT                | 3 IX2                | 2 IX1                | 1 IX                |
| 0A 5 1A                              |         | 3A 5                  | 4A 1                   | 5A 1                   | 6A 5                   | 7A 4                  | 8A 3                   | 9A 1                 | AA 2                 | BA 3                 | CA 4                 | DA 4                 | EA 3                 | FA 3                |
| BRSET5 BSET                          |         | DEC                   | DECA                   | DECX                   | DEC                    | DEC                   | PULH                   | CLI                  | ORA                  | ORA                  | ORA                  | ORA                  | ORA                  | ORA                 |
| 3 DIR 2 DI                           |         | 2 DIR                 | 1 INH                  | 1 INH                  | 2 IX1                  | 1 IX                  | 1 INH                  | 1 INH                | 2 IMM                | 2 DIR                | 3 EXT                | 3 IX2                | 2 IX1                | 1 IX                |
| 0B 5 1B                              |         | 3B 7                  | 4B 4                   | 5B 4                   | 6B 7                   | 7B 6                  | 8B 2                   | 9B 1                 | AB 2                 | BB 3                 | CB 4                 | DB 4                 | EB 3                 | FB 3                |
| BRCLR5 BCLR                          |         | DBNZ                  | DBNZA                  | DBNZX                  | DBNZ                   | DBNZ                  | PSHH                   | SEI                  | ADD                  | ADD                  | ADD                  | ADD                  | ADD                  | ADD                 |
| 3 DIR 2 DI                           |         | 3 DIR                 | 2 INH                  | 2 INH                  | 3 IX1                  | 2 IX                  | 1 INH                  | 1 INH                | 2 IMM                | 2 DIR                | 3 EXT                | 3 IX2                | 2 IX1                | 1 IX                |
| OC 5 1C<br>BRSET6 BSET<br>3 DIR 2 DI |         | 3C 5<br>INC<br>2 DIR  | 4C 1<br>INCA<br>1 INH  | 5C 1<br>INCX<br>1 INH  | 6C 5<br>INC<br>2 IX1   | 7C 4<br>INC 1         | 8C 1<br>CLRH<br>1 INH  | 9C 1<br>RSP<br>1 INH |                      | BC 3<br>JMP<br>2 DIR | CC 4<br>JMP<br>3 EXT | DC 4<br>JMP<br>3 IX2 | EC 3<br>JMP<br>2 IX1 | FC 3<br>JMP<br>1 IX |
| 0D 5 1D<br>BRCLR6 BCLR<br>3 DIR 2 DI |         | 3D 4<br>TST<br>2 DIR  | 4D 1<br>TSTA<br>1 INH  | 5D 1<br>TSTX<br>1 INH  | 6D 4<br>TST<br>2 IX1   | 7D 3<br>TST<br>1 IX   |                        | 9D 1<br>NOP<br>1 INH | AD 5<br>BSR<br>2 REL | BD 5<br>JSR<br>2 DIR | CD 6<br>JSR<br>3 EXT | DD 6<br>JSR<br>3 IX2 | ED 5<br>JSR<br>2 IX1 | FD 5<br>JSR<br>1 IX |
| 0E 5 1E<br>BRSET7 BSET<br>3 DIR 2 DI |         | 3E 6<br>CPHX<br>3 EXT | 4E 6<br>MOV<br>3 DD    | 5E 5<br>MOV<br>2 DIX+  | 6E 4<br>MOV<br>3 IMD   | 7E 5<br>MOV<br>2 IX+D | 8E 2+<br>STOP<br>1 INH | 9E<br>Page 2         | AE 2<br>LDX<br>2 IMM | BE 3<br>LDX<br>2 DIR | CE 4<br>LDX<br>3 EXT | DE 4<br>LDX<br>3 IX2 | EE 3<br>LDX<br>2 IX1 | FE 3<br>LDX<br>1 IX |
| 0F 5 1F                              | _       | 3F 5                  | 4F 1                   | 5F 1                   | 6F 5                   | 7F 4                  | 8F 2+                  | 9F 1                 | AF 2                 | BF 3                 | CF 4                 | DF 4                 | EF 3                 | FF 2                |
| BRCLR7 BCLR                          |         | CLR                   | CLRA                   | CLRX                   | CLR                    | CLR                   | WAIT                   | TXA                  | AIX                  | STX                  | STX                  | STX                  | STX                  | STX                 |
| 3 DIR 2 DI                           |         | 2 DIR                 | 1 INH                  | 1 INH                  | 2 IX1                  | 1 IX                  | 1 INH                  | 1 INH                | 2 IMM                | 2 DIR                | 3 EXT                | 3 IX2                | 2 IX1                | 1 IX                |

INH Inherent
IMM Immediate
DIR Direct
EXT Extended
DD DIR to DIR
IX+D IX+ to DIR

REL Relative
IX Indexed, No Offset
IX1 Indexed, 8-Bit Offset
IX2 Indexed, 16-Bit Offset
IMM to DIR
DIX+ DIR to IX+

SP1 Stack Pointer, 8-Bit Offset
SP2 Stack Pointer, 16-Bit Offset
IX+ Indexed, No Offset with
Post Increment
IX1+ Indexed, 1-Byte Offset with
Post Increment

Opcode in Hexadecimal SUB Instruction Mnemonic Addressing Mode

Table 7-2 Opcode Map (Sheet 2 of 2)

| DV 11 1 1 1      |        |     | able I     |                         | <br>Cor |       |                        | -/   |          |                        |                        |                         |
|------------------|--------|-----|------------|-------------------------|---------|-------|------------------------|------|----------|------------------------|------------------------|-------------------------|
| Bit-Manipulation | Branch | Rea | d-Modify-W |                         | Cor     | itroi |                        |      | Register | /Memory                |                        |                         |
|                  |        |     |            | 9E60 6<br>NEG<br>3 SP1  |         |       |                        |      |          | 9ED0 5<br>SUB<br>4 SP2 | SUB<br>SP1             |                         |
|                  |        |     |            | 9E61 6<br>CBEQ<br>4 SP1 |         |       |                        |      |          | 9ED1 5<br>CMP<br>4 SP2 | 9EE1 4<br>CMP<br>3 SP1 |                         |
|                  |        |     |            |                         |         |       |                        |      |          | 9ED2 5<br>SBC<br>4 SP2 | 9EE2 4<br>SBC<br>3 SP1 |                         |
|                  |        |     |            | 9E63 6<br>COM<br>3 SP1  |         |       |                        |      |          | 9ED3 5<br>CPX<br>4 SP2 | 9EE3 4<br>CPX<br>3 SP1 | 9EF3 6<br>CPHX<br>3 SP1 |
|                  |        |     |            | 9E64 6<br>LSR<br>3 SP1  |         |       |                        |      |          | 9ED4 5<br>AND<br>4 SP2 | l3 SP1                 |                         |
|                  |        |     |            |                         |         |       |                        |      |          | 9ED5 5<br>BIT<br>4 SP2 | 9EE5 4<br>BIT<br>3 SP1 |                         |
|                  |        |     |            | 9E66 6<br>ROR<br>3 SP1  |         |       |                        |      |          | 9ED6 5<br>LDA<br>4 SP2 | 9EE6 4<br>LDA<br>3 SP1 |                         |
|                  |        |     |            | 9E67 6<br>ASR<br>3 SP1  |         |       |                        |      |          | 9ED7 5<br>STA<br>4 SP2 | 9EE7 4<br>STA<br>3 SP1 |                         |
|                  |        |     |            | 9E68 6<br>LSL<br>3 SP1  |         |       |                        |      |          | 9ED8 5<br>EOR<br>4 SP2 | 9EE8 4<br>EOR<br>3 SP1 |                         |
|                  |        |     |            | 9E69 6<br>ROL<br>3 SP1  |         |       |                        |      |          | 9ED9 5<br>ADC<br>4 SP2 | 9EE9 4<br>ADC<br>3 SP1 |                         |
|                  |        |     |            | 9E6A 6<br>DEC<br>3 SP1  |         |       |                        |      |          | [4 SP2                 | 9EEA 4<br>ORA<br>3 SP1 |                         |
|                  |        |     |            | 9E6B 8<br>DBNZ<br>4 SP1 |         |       |                        |      |          | 9EDB 5<br>ADD<br>4 SP2 | 9EEB 4<br>ADD<br>3 SP1 |                         |
|                  |        |     |            | 9E6C 6<br>INC<br>3 SP1  |         |       |                        |      |          |                        |                        |                         |
|                  |        |     |            | 9E6D 5<br>TST<br>3 SP1  |         |       |                        |      |          |                        |                        |                         |
|                  |        |     |            |                         |         |       | 9EAE 5<br>LDHX<br>2 IX | LDHX | LDHX     | 9EDE 5<br>LDX<br>4 SP2 | LDX                    | LDHX                    |
|                  |        |     |            | 9E6F 6<br>CLR<br>3 SP1  |         |       |                        |      |          | 9EDF 5<br>STX<br>4 SP2 | 19FFF 4                | 19EEE 5 1               |

| INH  | Inherent   | REL  | Relative               | SP1  | Stack Pointer, 8-Bit Offset  |
|------|------------|------|------------------------|------|------------------------------|
| IMM  | Immediate  | IX   | Indexed, No Offset     | SP2  | Stack Pointer, 16-Bit Offset |
| DIR  | Direct     | IX1  | Indexed, 8-Bit Offset  | IX+  | Indexed, No Offset with      |
| EXT  | Extended   | IX2  | Indexed, 16-Bit Offset |      | Post Increment               |
| DD   | DIR to DIR | IMD  | IMM to DIR             | IX1+ | Indexed, 1-Byte Offset with  |
| IX+D | IX+ to DIR | DIX+ | DIR to IX+             |      | Post Increment               |

Note: All Sheet 2 Opcodes are Preceded by the Page 2 Prebyte (9E)

| Prebyte (9E) and Opcode in                                   | 9E60 6       | HCS08 Cycles                            |
|--------------------------------------------------------------|--------------|-----------------------------------------|
| Prebyte (9E) and Opcode in<br>Hexadecimal<br>Number of Bytes | NEG<br>3 SP1 | Instruction Mnemonic<br>Addressing Mode |